package fanjingzhu.check.dao;

import java.util.List;

import publics.model.ProposerGuarantee;

public interface ProposerGuaranteeDao {
	
	/**
	 * 保存一个申请人的对外担保记录到数据库
	 * @param guarantee 担保记录的实例        
	 * @return 主键id
	 */
	public Integer save(ProposerGuarantee guarantee);
	
	/**
	 * 根据id删除申请人的对外担保记录
	 * @param guaranteeId
	 * @return
	 */
	public boolean deleteById(Integer guaranteeId);
	
	/**
	 * 根据实例删除申请人的对外担保记录
	 * @param guarantee 申请人对外担保实例
	 * @return
	 */
	public boolean delete(ProposerGuarantee guarantee);
	

	/**
	 * 修改申请人对外担保的记录
	 * @param guarantee  申请人对外担保的一个实例
	 * @return  boolean 成功 true ，失败 false
	 */
	public boolean update(ProposerGuarantee guarantee);

	/**
	 * 据申请人对外担保的id查找 
	 * @param 公司表id
     * @return id对应的申请人对外担保记录的id
	 */
	public ProposerGuarantee findById(Integer id);
	
	/**
	 * 查询所有申请人的对外担保的记录
	 * @param hql 要查询的hql语句
	 * @param offset 起始条目偏移量（offset == （页码-1）*pageSize ，ajax传过来的start = offset ）
	 * @param pageSize  查询每页的条目数
	 * @return 查询的所有企业
	 */
	public List<ProposerGuarantee> findByPage(final String  hql, final int offset, final int pageSize);

	
	/**
	 * 分页查找的申请人对外担保的总记录
	 * @param sql 查询语句
	 * @return 记录总数
	 */
	public int findByCount(String sql);
	

}
